/****   request.js   ****/
// 导入axios
import axios from 'axios'
import qs from 'qs'
// 使用element-ui Message做消息提醒
import {Message} from 'element-ui';
import {getApiPath, getToken} from "./common";
//1. 创建新的axios实例，
axios.defaults.headers['Content-Type'] = "application/x-www-form-urlencoded"
const service = axios.create({
    baseURL: getApiPath(),
    timeout: 5 * 1000
})
// 2.请求拦截器
service.interceptors.request.use(config => {
    const token = getToken();
    if (config.headers['Content-Type'] == "application/x-www-form-urlencoded") {
        config.data = qs.stringify(config.data); //数据转化,也可以使用qs转换
    }
    if (token != null) {
        config.headers["Authorization"] = token
    }
    return config
}, error => {
    Promise.reject(error)
})

// 3.响应拦截器
service.interceptors.response.use(response => {
    //接收到响应数据并成功后的一些共有的处理，关闭loading等
    return response.data
}, error => {
    /***** 接收到异常响应的处理开始 *****/
    if (error && error.response) {
        // 1.公共错误处理
        // 2.根据响应码具体处理
        switch (error.response.status) {
            case 400:
                error.message = '错误请求'
                break;
            case 401:
                error.message = '未授权，请重新登录'
                break;
            case 403:
                error.message = '拒绝访问'
                //todo退出接口
                sessionStorage.clear()
                this.$router.push("/login");

                break;
            case 404:
                error.message = '请求错误,未找到该资源'
                break;
            case 405:
                error.message = '请求方法未允许'
                break;
            case 408:
                error.message = '请求超时'
                break;
            case 500:
                error.message = '服务器端出错'
                break;
            case 501:
                error.message = '网络未实现'
                break;
            case 502:
                error.message = '网络错误'
                break;
            case 503:
                error.message = '服务不可用'
                break;
            case 504:
                error.message = '网络超时'
                break;
            case 505:
                error.message = 'http版本不支持该请求'
                break;
            default:
                error.message = `连接错误${error.response.status}`
        }
    } else {
        error.message = '连接服务器失败'
        // 超时处理
        if (JSON.stringify(error).includes('timeout')) {
            error.message = '服务器响应超时，请刷新当前页'
        }
    }
    Message.error(error.message)
    /***** 处理结束 *****/
    //如果不需要错误处理，以上的处理过程都可省略
    return Promise.resolve(error.response.data)
})
//4.导入文件
export default service
